home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Wayzata's Best of Shareware PC/Windows 2
/
Wayzata's Best of Shareware 2.0 (Windows) (Wayzata Technology)(7112)(1994).bin
/
pc
/
dos
/
math
/
fsultra1
/
ultra_fr.asm
< prev
next >
Wrap
Assembly Source File
|
1992-06-18
|
3KB
|
119 lines
comment !
FSU - ULTRA The greatest random number generator that ever was
or ever will be. Way beyond Super-Duper.
(Just kidding, but we think its a good one.)
Authors: Arif Zaman (arif@stat.fsu.edu) and
George Marsaglia (geo@stat.fsu.edu).
Date: 27 May 1992
Version: 1.05
Copyright: To obtain permission to incorporate this program into
any commercial product, please contact the authors at
the e-mail address given above or at
Department of Statistics and
Supercomputer Computations Research Institute
Florida State University
Tallahassee, FL 32306.
See Also: README for a brief description
ULTRA.DOC for a detailed description
-----------------------------------------------------------------------
!
;
; File: ULTRA_FR.ASM (IBM Fortran/2 calling conventions)
;
DOSSEG
.MODEL HUGE,FORTRAN
;===== B: GLOBAL FUNCTIONS, SUBROUTINES and VARIABLES =================
;
public i31bit, i15bit, i7bit, i1bit, uni, duni
public i32bit, i16bit, i8bit, rinit, vni, dvni
public swbstate, swbsize
;===== D. MACRO DEFINITIONS ===========================================
;
; RinitProcStart should take two 32-bit arguments conx and shrx
; and place them in the data segment in congx and shrgx.
; es and ds should both point to the data segment.
; conx must be odd (so we or with 1 just to make sure).
; FillProc
; DS is already the data segment. ES should also be made the same.
EnterProcedure macro
mov dx,DATA
push ds
mov ds,dx
endm
ExitProcedure macro
pop ds
ret
endm
Enter2arg macro ; fortran has call by reference.
arg conx:dword, shrx:dword
EnterProcedure
mov dx,ds
mov es,dx
mov di,offset congx
lds si,ConX ; Store the parameters in
lodsw ; the data segment in
shl ax,1
stosw ; conglo:conghi and
lodsw ; shrglo:shrghi.
rcl ax,1
stosw
mov di,offset shrgx
lds si,ShrX
lodsw
stosw
lodsw
stosw
mov ds,dx ; setup the segment regs.
or byte ptr congx,1
endm
Exit2arg macro
ExitProcedure
endm
EnterFill macro
mov ax,ds
mov es,ax
endm
ExitFill macro
ret
endm
DwordFn macro
endm
WordFn macro
endm
ByteFn macro
cbw ; fortran doesn't have bytes so return integer*2
endm
RealFn macro
endm
DoubleFn macro
endm
DATA SEGMENT WORD PUBLIC 'F@DATA'
INCLUDE ULTRADAT.INC
DATA ENDS
F@ICODE SEGMENT WORD PUBLIC 'CODE'
ASSUME CS:F@ICODE, DS:DATA
INCLUDE ULTRACOD.INC
F@ICODE ENDS
END